Syft Keras सह खाजगी भविष्यवाण्या (Private Predictions with Syft Keras)

चरण 1: सार्वजनिक प्रशिक्षण

या पाठात आपले स्वागत आहे! पुढील नोटबुकमध्ये आपण खाजगी अंदाज कसे द्यायचे ते शिकाल. खाजगी अंदाजानुसार, आमचा अर्थ असा आहे की संपूर्ण प्रक्रियेमध्ये डेटा सतत कूटबद्ध केला जातो. कोणत्याही क्षणी वापरकर्ता कच्चा डेटा सामायिक करत नाही, केवळ कूटबद्ध केलेला (म्हणजे गुप्त सामायिक) डेटा आहे. ही खाजगी भविष्यवाणी करण्यासाठी, Syft Keras हूड च्या खाली TF Encrypted नावाची लायब्ररी वापरते. TF एन्क्रिप्टेड मध्ये अत्याधुनिक क्रिप्टोग्राफिक आणि मशीन लर्निंग तंत्र एकत्रित केले आहे, परंतु आपल्याला याबद्दल काळजी करण्याची आवश्यकता नाही आणि आपल्या मशीन लर्निंग अनुप्रयोगावर लक्ष केंद्रित करू शकता.

आपण केवळ तीन चरणांसह खाजगी भविष्यवाण्या देण्यास प्रारंभ करू शकता:

  • चरण 1: आपल्या मॉडेलला सामान्य केरास प्रशिक्षण द्या.
  • चरण 2: आपल्या मशीन लर्निंग मॉडेलला (सर्व्हर) सुरक्षित करा आणि सर्व्ह करा.
  • चरण 3: खासगी अंदाज (क्लायंट) प्राप्त करण्यासाठी सुरक्षित मॉडेलची चौकशी करा.

ठीक आहे, चला या तीन चरणांमध्ये जाऊ या म्हणजे आपण वापरकर्त्याची गोपनीयता किंवा मॉडेल सुरक्षिततेचा बळी न देता प्रभावी मशीन लर्निंग सेवा तैनात करू शकता.

लेखक:

अनुवादक/संपादक:

इनकी ओर से:

आपल्या मॉडेलला Keras सह प्रशिक्षण द्या

आपल्या प्रकल्पांसाठी गोपनीयता-संरक्षित मशीन लर्निंग तंत्र वापरण्यासाठी आपल्याला नवीन मशीन लर्निंग फ्रेमवर्क शिकण्याची गरज नाही. आपल्याकडे Keras चे मूलभूत ज्ञान असल्यास आपण Syft Keras द्वारे या तंत्रे वापरण्यास प्रारंभ करू शकता. जर आपण यापूर्वी कधीही Keras वापरला नसेल तर आपण Keras प्रलेखन द्वारे त्याबद्दल थोडेसे जाणून घेऊ शकता.

खाजगी अंदाज देण्यापूर्वी, पहिली पायरी म्हणजे आपल्या मॉडेलला सामान्य केरास प्रशिक्षण देणे. उदाहरणार्थ, आम्ही हस्तलिखित अंकांचे वर्गीकरण करण्यासाठी मॉडेलला प्रशिक्षण देऊ. हे मॉडेल प्रशिक्षित करण्यासाठी आम्ही अधिकृत MNIST डेटासेट वापरू.

हे उदाहरण आम्ही केरास रेपॉजिटरी मधून घेत आहोत. आपल्या वर्गीकरण मॉडेलचे प्रशिक्षण घेण्यासाठी आपण फक्त खालील सेल चालवा.


In [ ]:
from __future__ import print_function
import tensorflow.keras as keras
from tensorflow.keras.datasets import mnist
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Dense, Dropout, Flatten
from tensorflow.keras.layers import Conv2D, AveragePooling2D
from tensorflow.keras.layers import Activation

batch_size = 128
num_classes = 10
epochs = 2

# input image dimensions
img_rows, img_cols = 28, 28

# the data, split between train and test sets
(x_train, y_train), (x_test, y_test) = mnist.load_data()

x_train = x_train.reshape(x_train.shape[0], img_rows, img_cols, 1)
x_test = x_test.reshape(x_test.shape[0], img_rows, img_cols, 1)
input_shape = (img_rows, img_cols, 1)

x_train = x_train.astype('float32')
x_test = x_test.astype('float32')
x_train /= 255
x_test /= 255
print('x_train shape:', x_train.shape)
print(x_train.shape[0], 'train samples')
print(x_test.shape[0], 'test samples')

# convert class vectors to binary class matrices
y_train = keras.utils.to_categorical(y_train, num_classes)
y_test = keras.utils.to_categorical(y_test, num_classes)

model = Sequential()

model.add(Conv2D(10, (3, 3), input_shape=input_shape))
model.add(AveragePooling2D((2, 2)))
model.add(Activation('relu'))
model.add(Conv2D(32, (3, 3)))
model.add(AveragePooling2D((2, 2)))
model.add(Activation('relu'))
model.add(Conv2D(64, (3, 3)))
model.add(AveragePooling2D((2, 2)))
model.add(Activation('relu'))
model.add(Flatten())
model.add(Dense(num_classes, activation='softmax'))

model.compile(loss=keras.losses.categorical_crossentropy,
              optimizer=keras.optimizers.Adam(),
              metrics=['accuracy'])

model.fit(x_train, y_train,
          batch_size=batch_size,
          epochs=epochs,
          verbose=1,
          validation_data=(x_test, y_test))
score = model.evaluate(x_test, y_test, verbose=0)
print('Test loss:', score[0])
print('Test accuracy:', score[1])

भविष्यातील खाजगी अंदाजासाठी आपल्या मॉडेलचे वजन जतन करा

मस्त! आपले मॉडेल प्रशिक्षित आहे. model.save() सह मॉडेल वजनाची बचत करूया. पुढील नोटबुकमध्ये आम्ही खाजगी अंदाज वर्तविणे सुरू करण्यासाठी हे वजन वजन Syft Keras मध्ये लोड करू.


In [ ]:
model.save('short-conv-mnist.h5')

In [ ]: